
Pf^T 1 WELTORGANISAnON FOR GEISTIGES EIGENTUM 

* X Internationales Bflro 

INTERNATIONALE ANMELDUNG VEROFFENTLICHT NACH DEM VERTRAG OBER DIE 
INTERNATIONALE ZUSAMMEN ARBEIT AUF DEM GEBIET PES PATENTWESENS (PCT) 



(51) Internationale Patentklassffikalion 6 : 
G06F 15/78, H03K 19/177 



Al 



(11) Internationale Veroffenffichungsnumrner; WO 98/28697 



(43) Internationales 

Veroflentl ich ungsda turn : 



(21) Internationales Aktenzeichen: 

(22) Internationales Anmeldedatum: 



PCT/DE97/03013 

21. Dczcmber 1997 
(21.12.97) 



ZJuli 1998 (02.07.98) 



(30) Prioritatsdaten: 
196 54 595.1 



20. Dczember 1996 (20.12.96) DE 



(71) Anmeider (fur alle Bcstimmungsstaaten ausser US)i PACT IN- 

FORMATIONSTECHNOLOGIE GMBH [DE/DBJ; Thele- 
mannstrasse 15, D-81545 Munchen (DE). 

(72) Erfinder; und 

(75) Erfinder/Anmelder (nur fur US): VORBACH, Martin 
rDE/DE]; Hagebuttenweg 36. I>-76J49 Karlsruhe (DE). 
MflNCH, Robert [DE/DE]; Hagebuttenweg 36, D-76149 
Karlsruhe (DE). 



(81) Bestimmungsslaaten: AL. AM, AT. AU, AZ, BA, BB, BG, 
BR, BY, CA, CH, CN, CU, CZ. DE, DK, EE, ES, FI, 
GB, GE, GH, GM, HU, ID, IL, IS, JP, KE. KG, KP, KR, 
KZ, LC, LK, LR, LS, LT, LU, LV, MD, MG, MK, MN, 
MW, MX, NO, NZ, PL, PT, RO, RU, SD, SE, SG, SI, SK, 
SL, 17, TM, TR, TT, UA, UG, US, UZ, VN, YU, ZW, 
ARIPO Patent (GH, GM, KE, LS, MW, SD, SZ, UG, ZW) 
eurasisches Patent (AM, AZ, BY, KG, KZ, MD, RU, TJ, 
TM), europaisches Patent (AT, BE, CH, DE, DK, ES, FI 
FR, GB, GR, IE. IT, LU, MC, NL, PT, SE), OAP1 Patent 
(BF, BJ, CF, CG, CI, CM, GA, GN, ML, MR, NE, SN, TD, 
TO). 



VeroffentBcht 

Mit inUrnationalemRecherchenbericht. 

Vor AbUmfderjurAndcrungtn der Anspruche zugelassenen 

Frist, Ver&ffentlichimg wird wiederholt fails Anderungen 

eintrefferu 



(54) Utie: 10- AND MEMORY BUS SYSTEM FOR DFPs AS UNITS WITH TWO- OR MULTT-DIMENSIONALLY PRO- 
GRAMMABLE CELL STRUCTURES 

(54) Bezeicfanung: IO- UND SPEICHERBUSS YSTEM FUR DFPs SOWIE BAUSTEINE MIT ZWEI- ODER MEHRDIMENSIONALEN 
PROGR AMM1ERB AREN ZELLSTRUKTUREN 

(57) Abstract 

The invention relates to a bus system produced by concentrating individual conductors or buses within a unit of the type DFP, FPGA, 
DPGA, as well as all units with two- or multi-dimensionally programmable cell structure, and via which the units can be assembled to 
form several and/or can be connected to a memory and/or a periphery. 

(57) Zusammenfassung 

Es wird ein Bussystem vorgeschlagen, das durch BQndelung mehrerer einzeuier Leitungen Oder Busse oder Teilbusse mnerhalb eines 
Baustdnes der Gattung DFP, FPGA, DPGA, sowie alien Bausteinen mit zwei- oder mehrdimerisionaler programmieibaier Zellstruktur 
hergestelit ist, und uber welches die Bausteine zu Mehrcren rusammengefafit werden konnen und/oder Speicher und/oder Peripherie 
anschlieBbar sind/ist 
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10- und Speicherbussystem fur DFPs sowie Bausteine mit zwei- 
Oder mehrdimensionalea programmierbaren Zellstrukturen 

1. Hintergrund der Erfindung 

1.1 Stand der Technik 

1.1.1 ... in DFP-basierenden Systemen 

In DFPs gemaft DE 44 16 881 Al werden die Leitungen jeder 
Kantenzelle, das ist eine Zelle, die sich am Rand eines 
Zellarrays befindet und oftmals direktet Kontakt mit den 
Anschltfssen des Bausteines haben kann, Ober die Anschliisse des 
Bausteines herausgefuhrt . Dabei haben die Leitungen keine 
spezielle Funktion, vielmehr Ubernehmen sie die Funktion, die in 
den Kantenzellen beschrieben, ist . Werden mehrere DFPs miteinander 
vernetzt, so werden alle Anschlusse zu einer Matrix miteinander 
verbunden. 

1.1.2 ... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen (FPGAs, DPGAs) 
In Systemen mit zwei- oder mehrdimensionalen programmierbaren 
Zellstrukturen (FPGAs, DPGAs) wird eine bestimmte Teilmenge von 
internen Bussystemen und Leitungen der Kantenzellen uber die 
AnschlUsse des Bausteines herausgefqhrt . Dabei haben die 
Leitungen keine spezielle Funktion, vielmehr Obernehmen sie die 
Funktion, die in den Kantenzellen beschrieben ist. Werden mehrere 
FPGAs /DPGAs miteinander vernetzt, so ttbernehmen die Anschlusse 
die Funktion, die hardware oder softwareseitig implementiert 
wurde. 
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1.2 Probleme 

1.2.1 ... in DFP-basierenden Systemen 

Der Verdrahtungsaufwand fiir die Peripherie Oder Vernetzung von 
DFPs ist sehr hoch. Da gleichzeitig der Programmierer daftir zu 
sorgen hat, daB die entsprechenden Funktionen in die Zellen 
des/der DFPs integriert werden. Zum Anschlufc eines Speichers muft 
eine Speicherverwaltung in den Baustein integriert werden. Zum 
Anschlufl von Peripherie muft diese untersttitzt werden, ebenso wie 
die Kaskadierung von DFPs entsprechend berucksichtigt werden muft. 
Der Aufwand ist verhaltnismafiig hoch, gleichzeitig geht FlSche 
auf dem Baustein fur die jeweiligen Implement ierungen verloren. 

1.2.2 — in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen (FPGAs, DPGAs) 

Oben beschriebenes gilt ebenfalls ftir FPGAs und DPGAs, ins 
besondere, wenn diese zur Implementierung von Algorithmen 
eingesetzt werden und als numerische (Co) Prozessoren arbeiten. 

1.3 Verbesserung durch die Erfindung, Aufgabe 
Der Verdrahtungsaufwand, ins besondere die Anzahl der 
Bausteinanschlusse wird erheblich reduziert. Ein einheitliches 
Bussystem arbeitet ohne besondere ftticksichtnahme durch den 
Programmierer. Die Steuerung des Bussystems ist fest 
implement iert. Ohne besondere Mafinahmen kann an das Bussystem 
Speicher, sowie Peripherie angeschlossen werden. Ebenfalls konnen 
Bausteine mit Hilfe das Bussystems kaskadiert werden. 

2. Beschreibung der Erfindung 

2.1 Obersicht fiber die Erfindung, Abstrakt 

Die Erfindung beschreibt ein allgemeines Bussystem, das eine 
Vielzahl bausteininterner Leitungen zusammenfaBt und als Bundel 
an die AnschlUsse herausfiihrt. Die Steuerung des Bussystems ist 
dabei vordef iniert und bedarf. keines Einflusses durch den 
Programmierer. An das Bussystem lassen sich beliebig Speicher, 
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Peripherie oder weitere Bausteine zur Kaskadierung anschlieften . 
. Die Einzelheiten und besondere Ausgestaltungen, sowie Merkmale 
des erf indungsgema&en Bussystems sind Gegenstand der 
Patentanspriiche . 

2,2 Detailbeschreibung der Erfindung 

Die nachfolgende Beschreibung umfaflt mehrere Strukturen f die wie 
bei DFPs, FPGAs, DPGAs , o.a. ublich von einer Ladelogik aus 
gesteuert und konfiguriert werden. Dabei konnen Teile der 
Ladelogik auf dem Baustein integriert sein. Alternativ besteht 
die Moglichkeit (Fig. 6/7) die Strukturen durch den Baustein 
selbst direkt dynamisch umzukonf igurieren oder zu steuern. Dabei 
konnen die Strukturen fest auf dem Baustein iraplementiert sein, 
oder erst durch Konf iguration und moglicherweise Zusammenschlufc 
mehrere Logikzellen, das sind konfigurierbare Zelleen, die 
einfache logische ode arithmetische Aufgaben gemaft ihrer 
Konfiguration erftillen (vgl. DFP, FPGA, DPGA) , entstehen. 

2,2.1 Bundelung interner Leitungen} 

Um sinnvolle Busstrukturen zu erhalten, wird eine Mehrzahl 
interner Leitungen wird zu Bussen (I-BUSn; n gibt die Nummer des 
Busses an) zusammengefafct . Dabei kann es sich bei den Leitungen 
um interne Bussysteme oder um Leitungen der Kantenzellen handeln. 
Die einzelnen Busse werden far Schreibzugrif f e auf den externen 
Bus (E-BOS) tlber taktsynchrone Latche oder Register (I -GATE-REG) 
auf Tore gefuhrt, die als Schalter zum E-BUS arbeiten. Eine 
derartige Einheit wird Ausgabezelle (OUTPUT-CELL) genannt. Der 
Zugriff auf den E-BUS geschieht derart, daB die einzelnen Latche 
tiber die Tore auf den gemeinsamen E-BUS geschaltet werden. Dabei 
ist imraer nur ein Tor gedffnet. Jeder I-BUSn besitzt eine 
eindeutige Kennummer (n: z.B. I-BUS1, I-BUS976, ...). 
FUr Lesezugrif fe wird der hereinfahrende E-BUS in taktsynchrone 
Latche oder Register (E -GATE -REG) zwischengespeichert und dann 
aber die Tore an die I-BUSn verteilt .Eine derartige Einheit wird 
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Eingabezelle (INPUT-CELL) genannt. Der Abgriff vom E-BUS 
geschieht dabei derart, da& ein E-BUS-Transf er in ein oder 
mehrere E --GATE-REG geschrieben wird.. Die E-GATE-REG konnen dann 
entweder einzeln oder gemeinsam auf ihre inteirnen Bussysteme 
freigeschaltet werden. 

Dabei kfcnnen die Schreib-VLesezugrif f e in beliebiger Reihenfolge 
ablaufen. Es ist unter UmstSnden sinnvoll die internen Busse I- 
BUSn in zwei Gruppen zu unterteilen, die schreibenden 
Ausgabebusse 10-BUSn und die lesenden Eingabebusse II-BUSn. 

2.2,2 Adressgenerierung 

Fur die meisten Zugriffe auf externe Bausteine ist es notwendig 
Adressen zur Auswahl eines Bausteines oder Teilen eines 
Bausteines zu generieren. Dabei konnen die Adressen fest sein, 
das heifct sie Sndern sich nicht (dies ist vor allem bei 
Peripherieadressen der Fall) oder die Adressen verandern sich bei 
jedem Zugriff urn (meist) feste Werte (dies ist vor allem bei 
Speicheradresssen der Fall) . ,Zur Generierung der Adressen 
existieren programmierbare ZShler fur die Lesezugriffe und 
programmierbare zahler far die Schreibzugrif fe. Die Zahler werden 
durch die Ladelogik, das ist die Einheit, die die, auf einer 
Zellstruktur basiereriden konf igurierbaren Bausteine (DFPs, FPGAs , 
DPGAs o*a.) konfiguriert, auf einen Grundwert eingestellt. Bei 
jedem Zugriff auf das Tor zahlt der ZShler je nach Einstellung um 
einen von der Ladelogik festgelegten Wert nach oben oder unten. 
Ebenfalls kann jeder zahler als Register verwendet werden, das 
bedeutet, bei einem Zugriff wird nicht gezahlt, der im Zahler 
eingestellte Wert ist statisch. Jedem Bustransfer wird als 
Adresse der Wert des zum Tor gehdrenden zahlers zugeordnet. Die 
Einstellung des Zahlers geschieht uber ein Einstellungsregister 
(MODE-PLUREG) , das von der Ladelogik beschrieben wird. 
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2,2.3 Masken und Zustande 

Jedem Tor ist eine Anzahl Bit's im spSter beschriebenen MODE- 
PLUREG zugeordnet, die angibt, ob der Tor aktiv ist oder von der 
Steuerung ubergangen wird, also ausmaskiert ist (MASKE) . Das 
bedeutet, der Tor wird beim Durchlaufen aller Tor zum Aufschalten 
auf das jeweilige Bussystem Ubergangen. 
Folgende Masken-Eintrage sind denkbar: 

- I N PUT- / OUT PUT- CELL immer ubergehen 

- IN PUT- / OUT PUT-CELL nur beim Schreiben Qbergehen 

- INPUT-/OUTPUT-CELL nur beim Lesen iibergehen, wenn der E-BUS- 
MAS\-TER nicht auf die INPUT-/OUTPUT-CELL zugegriffen hat 

- INPUT- /OUTPUT-CELL nieraals tibergehen 

Jedem Tor ist ein Zustandsregister, das als RS-Flipflop 
ausgestaltet sein kann, zugeordnet. Dieses Register zeigt an, ob 
Daten in das zum Tor gehorenden Register geschrieben wurden. 

2.2.4 Das MODE- PLUREG 

Das MODE- PLUREG kann von der Ladelogik beschrieben und gelesen 
werden. Es dient zur Einstellung des Bussys terns. 



Ein maglicher Aufbau des MODE-PLUREG aus Sicht der Ladelogik 
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0=Register 
l=ZShler 


maskieren 


Einstellungen fur Adressgenerator 
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2.2.5 Beschreibung der INPUT-CELL 

Es wird unterschieden, ob Oaten vom E-BUS in den Baustein 
gelangen (die dafiir notwendige Einheit wird INPUT-CELL genannt) 
Oder ob Daten aus dem Baustein auf den E-BUS gelangen (die dafiir 
notwendige Einheit wird OUTPUT-CELL genannt). 

Eine INPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (I- 
GATE-REG), das entweder vom externen E-BUS-MASTER oder der 
bausteineigenen Zustandsmaschine gesteuert wird, dient zur 
Zwischenspeicherung der Daten, die vom E-BUS erhalten werden. 
Dabei ist das Taktsignal des Latches an ein (z.B.) RS-Flipflop 
(SET-REG) gefQhrt, das den Zugriff auf das I-GATE-REG festhait. 
Hinter dem I-GATE-REG befindet sich ein Tor (I -GATE) , das von der 
Zustandsmaschine gesteuert wird.Ober das I -GATE gelangen die 
Daten aus dem I-GATE-REG auf den I(I)-BUSn. 

Des weiteren befindet sich ein programmierbarer auf/abwSrts- 
zahler in der INPUT-CELL. Er kann nach jedem aktiven Lesezugriff 
auf den E-BUS durch die Zustandsmaschine gesteuert, urn einen 
einstellbaren Wert hoch- oder herunterzahlen. Ebenfalls kann er 
als einfaches Register dienen. Dieser Zahler generiert die 
Adressen fttr Buszugriffe, in denen der Baustein E-BUS-MASTER ist. 
Die Adressen werden durch ein Tor (ADR-GATE) auf den E-BUS 
gefahrt. 

Das ADR-REG wird von der Zustandsmaschine gesteuert. 

Ober ein weiteres Tor (STATE-GATE) kann der E-BUS-MASTER den 
Zustand des SET-REG abfragen. Jede INPUT-CELL besitzt ein MODE- 
PLUREG, in dem die Ladelogik den Zahler konfiguriert und die 
INPUT-CELL aus- oder einschaltet (maskiert) . 
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2.2.6 Beschreibung der OUTPUT-CELL 

Eine OUTPUT-CELL kann wie folgt ausgestaltet sein: Ein Latch (E- 
GATE-REG), das von der bausteineigenen Zustandsraaschine gesteuert 
wird, dient zur Zwischenspeicherung der Daten, die vom I-BUS 
erhalten werden. 

Des weiteren befindet sich ein programmierbarer auf/abwarts- 
ZMhler in der OUT- PUT-CELL ♦ Dabei ist das Taktsignal des Latches 
an ein (z.B.) RS-Flipflop (SET-REG) geftthrt, das den Zugriff auf 
das E-GATE-REG festhait. Er kann nach jedem aktiven Lesezugriff 
auf den E-BUS durch die Zustandsmaschine gesteuert, um einen 
einstellbaren Wert hoch- Oder herunterzShlen. Ebenfalls kann er 
als einf aches Register dienen. Dieser ZShler generiert die 
Adressen fur Buszugriffe, in denen der Baustein E-BUS-MASTER ist. 

Die Daten des E-GATE-REG, die Adressen und der Zustand des SET- 
REG werden uber ein Tor (E-GATE) , das entweder vom externen E- 
BUS-MASTER oder der bausteineigenen Zustandsmaschine gesteuert 
wird, auf den geftlhrt. Jede OUTPUT-CELL besitzt ein MODE-PLUREG, 
in dem die Ladelogik den Zahler konfiguriert und die OUTPUT-CELL 
aus- oder einschaltet (maskiert) . 

2.2.7 Steuerung des Bussystems 

Den einzelnen Toren, Adressgeneratoren und Masken ist eine 
Steuerung Ubergeordnet . Diese besteht aus einer einfachen 
Zustandsmaschine nach dem Stand der Technik. Dabei werden zwei 
Betriebsarten unterscheiden: 

1. Eine Aktive, in der die Zustandsmaschine den internen Bus (I- 
BUS) und den externen Bus (E-BUS) steuert. Diese Betriebsart 
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wird E-BUS-MASTER genannt, da die Zustandsmaschine die 
Kontrolle titer den E-BUS besitzt. 
2. Eine Passive, in der die Zustandsmaschine nur den internen Bus 
(I-BUS) steuert. Der E-BUS wird von einem anderen externen 
Baustein kontrolliert . Die Zustandsmaschine reagiert in dieser 
Betriebsart auf die Anf orderungen des externen E-BUS-MASTERS. 
Diese Betriebsart wird E-BUS-SLAVE genannt. 

Die Steuerung verwaltet das E-BUS Protokoll. Dabei ist der Ablauf 
unterschiedlich, je nachdem, ob die Steuerung als E-BUS-MASTER 
Oder E-BUS-SLAVE arbeitet. Ein Busprotokoll wird in dieser 
Schrift nicht beschrieben, da eine Vielzahl von Protokollen nach 
dem Stand der Technik implementiert werden konnen. 

2.2.8 E-BUS-MASTER und E-BUS-SLAVE, das EB-REG 

Zur Verwaltung des Datenverkehrs auf dem E-BUS existiert das E- 
BUS-Steuerregister (EB-REG) . Es ist in Reihe mit den Toren 
geschaltet und kann vom E-BUS aus adressiert und angesprochen 
werden. Ober folgende Eintrage konnte der Datenaustausch geregelt 
werden: 

I-WRITE: zeigt an, daB der I-BUS komplett in die INPUT- /OUTPUT- 

CELLs geschrieben ist 
I -READ : zeigt an, daft der I-BUS die INPUT- /OUTPUT-CELLs komplett 

gelesen hat 

E-WRITE: zeigt an, daB der E-BUS komplett in die INPUT-/OUTPUT- 

CELLs geschrieben ist 
E-READ : zeigt an, daB der E-BUS die INPUT- /OUTPUT-CELLs komplett 
gelesen hat 
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Das EB-REG ist immer nur auf der Seite des E-BUS-SLAVE aktiv und 
der E-BUS-MASTER greift lesend und schreibend darauf zu. 

- Alle I-. . . -EintrSge werden vom E-BUS-SLAVE geschrieben und vom 
E-BUS-MASTER gelesen. 

- Alle E-. . . -Eintr^ge werden vom E-BUS-MASTER geschrieben und vom 
E-BUS-SLAVE gelesen. 

Ein E-BUS-SLAVE kann die Kontrolle Ober den E-BUS fordern, in dem 
er das Bit REQ-MASTER in seinem EB-REG setzt. Erkennt der E-BUS- 
MASTER das Bit REQ-MASTER, so mufc er seine Buskontrolle so bald 
wie moglich abgeben. Dies geschieht, in dem er das Bit MASTER im 
EB-REG eines E-BUS-SLAVE setzt. Er schaltet darauf hin sofort die 
E-BUS passiv. Der alte E-BUS-SLAVE wird zum neuen E-BUS-MASTER 
und der alte E-BUS-MASTER wird zum neuen E-BUS-SLAVE. Der neue E- 
BUS-MASTER ttbernimmt die Steuerung des E-BUS. Zur Erkennung des 
ersten E-BUS-MASTERs nach einer Riicksetzung (RESET) des Systems, 
existiert ein AnschluJi an jedem Baustein, der durch die 
voreingestellte Polaritat angibt f ob der Baustein nach 
einem RESET E-BUS-MASTER Oder E-BUS-SLAVE ist. Der Eintrag MASTER 
im EB-REG kann auch von der Ladelogik gesetzt und zuruckgesetzt 
werden. Dabei hat die Ladelogik darauf zu achten, daft keinerlei 
Buskollisionen am EB-BUS entstehen oder laufende 
Transfers abgebrochen werden. 

2.2.9 E-BUS-MASTER schreibt Daten in E-BUS-SLAVE 

Folgendermafien kann der E-BUS-MASTER Daten in den E-BUS-SLAVE 
schreiben: 
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=> Die Dateniibertragung beginnt damit, daft die Zustandsmaschine 
des E-BUS-MASTERs eine OUTPUT-CELL auswShlt, die nicht 
ausmaskiert ist. 

Im I-GATE-REG sind, je nach Ausfilhrung der Zustandsmaschine, 
bereits Daten gespeichert Oder die Daten werden jetzt 
gespeichert. 
=> Das Tor wird aktiviert. 

-» Die gultige Leseadresse wird auf den Bus iibertragen. 
-» Die Daten gelangen auf den E-BUS und werden in das E-GATE- 
REG des E-BUS-SLAVE gespeichert. 

=> Dadurch wird das SET-REG im E-BUS-SLAVE aktiviert. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fUr den nachsten 

Zugriff . 

=> Der Transfer ist fur den E-BUS-MASTER beendet. 

Auf der Seite des E-BUS-SLAVE existieren zwei 
AusgestaltungsmSglichkeiten die Daten vom Bus in den Baustein 
zu transferieren: 

1. Das Daten-Tor ist immer of fen und die Daten gelangen direkt 
vom E-GATE-REG auf den I-BUSn. 

2. Die Zustandsmaschine erkennt, daB SET-REG aktiviert ist und 
aktiviert das Tor, dadurch kann SET-REG zurOckgesetzt werden. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein 
kompletter Buszyklus beendet ist. (Ein Buszyklus ist als das 
Obertragen mehrerer Datenworte an unterschiedliche E-GATE-REG 
definiert, wobei jedes E-GATE-REG genau ein Mai angesprochen 
werden darf . } 
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=> Dazu setzt der E-BUS-MASTER am Ende eines Buszyklus das Bit E- 

WRITE im EB-REG des E-BUS-SLAVE. 
=> Der E-BUS-SLAVE kann darauf reagieren, in dem er die INPUT- 
CELLs abfragt. 

=> Hat er alle INPUT-CELLs abgearbeitet, setzt er das Bit I -READ 
in seinem EB-REG. 

=> Dabei setzt er E-WRITE und samtliche SET-REG der INPUT-CELLs 
zurOck. 

=> Der E-BUS-MASTER kann I -READ abfragen und nach dessen 

Aktivierung einen neuen Buszyklus beginnen. 
=> I -READ wird durch Schreiben von E-WRITE oder den ersten 

Bustransfer zurUckgesetzt . 

Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der 
einzelnen SET-REG der INPUT-CELLs auswerten, ob die INPUT-CELLs 
neu gelesen werden kbnnen/mussen. 

2.2.10 E-BUS-MASTER liest Daten von E-BUS-SLAVE 

Aus der Sicht des E-BUS-MASTERs existieren zwei grundlegende 
Methoden Daten vom E-BUS-SLAVE zu lesen: 

1. Verfahren, in dem die E-BUS-Daten direkt auf den I-BUS 
gelangen: 

=> Die Datentibertragung beginnt damit, daft die Zustandsmaschine 
des E-BUS-MASTERs eine INPUT-CELL auswahlt, die nicht 
ausmaskiert ist. 

=> Das I -GATE und das ADR-GATE werden aktiviert. 
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Die gultige Leseadresse wird auf den Bus ubertragen. 

=> Das I -GATE-REG ist transparent, d.h. es laflt die Daten auf den 
I-BUSn durch. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fur den nachsten 
Zugriff . 

=> Der Transfer ist fur den E-BUS-MASTER beendet. 

2. Verfahren, in dem die E-BUS-Daten im I-GATE-REG 
zwischengespeichert werden: 

=> Die DatenUbertragung beginnt damit, daft die Zustandsmaschine 
des E-BUS-MASTERs eine INPUT-CELL auswahlt, die nicht 
ausmaskiert ist. 

Das I -GATE und das ADR- GATE werden aktiviert. 

-> Die gultige Leseadresse wird auf den Bus Ubertragen. 

=> Das I-GATE-REG speichert die Daten. 

=> Das Tor im E-BUS-MASTER wird deaktiviert. 

=> Der Adresszahler generiert die Adresse fur den nachsten 
Zugriff. 

=> Der E-BUS-Transfer ist fUr den E-BUS-MASTER beendet. 

=> Alle am E-BUS-Transfer beteiligten INPUT-CELLs, dies kann 

anhand der Masken in den MODE-PLUREG oder dem Zustand der SET- 
REG festgestellt werden, werden durchlaufen und die Daten auf 
den jeweiligen I-BUS Ubertragen. 

FUr den E-BUS-SLAVE sieht der Zugriff wie folgt aus: 
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=> Durch den E-BUS wird das Tor aktiviert. 

=> Die Daten und der Zustand des moglicherweise vorhandenen SET- 
REG gelangen auf den E-BUS. 
=> Das Tor wird deaktiviert. 

Der E-BUS-MASTER kann dem E-BUS-SLAVE mitteilen, wann ein 
kompletter Buszyklus beendet ist. 

=>Dazu setzt der E-BUS-MASTER am Ende eines Buszyklus das Bit E- 
READ im EB-REG des E-BUS-SLAVE. 

=*Der E-BUS-SLAVE kann darauf reagieren, in dem er die OUTPUT- 
CELLs neu beschreibt. 

=>Hat er alle OUTPUT-CELLs abgearbeitet/ setzt er das Bit I-WRITE 
in seinem EB-REG. 

=*Dabei setzt er E-READ und sSmtliche SET-REG der OUTPUT-CELLs 
zurtick. 

=>Der E-BUS-MASTER kann I-WRITE abfragen und nach dessen 

Aktivierung einen neuen Buszyklus beginnen. 
=>I-WRITE wird durch Schreiben von E-READ oder den ersten 

Bustransfer zuruckgesetzt . 

Der E-BUS-SLAVE kann anhand des Zustandes des EB-REG oder der 
einzelnen SET-REG der OUTPUT-CELLs auswerten, ob die OUTPUT- 
CELLs neu beschrieben werden kSnnen/miissen. 

2.2.11 AnschluB von Speicher, Peripherie und Kaskadierung 

AuBer der Kaskadierung von gleichen Bausteinen (DFPs, FPGAs, 
DPGAs) kann an das beschriebene Bussystem Speicher und Peripherie 
als untergeordnete SLAVE-BauStein (SLAVE) angeschlossen werden. 
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Dabei kann Speicher und Peripherie/ sowie weitere Bausteine 
(DFPs, FPGAs) gemischt werderv. Jeder angeschlossene SLAVE wertet 
die Adressen auf dem Bus aus und erkennt selbstandig ob er 
angesprochen ist. In diesen Betriebsarten ist der Baustein, der 
den Speicher oder die Peripherie, also die SLAVE-Bausteine 
anspricht, der Bus-MASTER (MASTER), d.h. der Baustein steuert den 
Bus und den Datentransf er . Die Ausnahme bilden intelligente 
Peripheriebausteine, wie z.B. SCSI-Kontroller, die selbstandig 
Transfers initieren und durchfuhren konnen und daher E-BUS-MASTER 
sind. 



2.2.12 Zusammenfassung 

Durch das beschriebene Verfahren, lassen sich Bussysteme einfach 
und leistungsfShig an DFPs und FPGAs anschliefien. Dabei konnen 
uber die Bussysteme sowohl Speicher und Peripherie, als auch 
weitere Bausteine o.g. Gattung verbunden werden. 

Das Bussystem mufl nicht ausschlieBlich in den DFPs, FPGAs und 
DPGAs implemetiert sein. Selbstverstandlich ist ein Mischbetrieb 
dieses Bussystemes mit den herkSmmlichen Anschluftstrukturen der 
Bausteinemoglich. Damit konnen die Vorteile der jeweiligen 
Technik optimal genutzt werden. 

Es sind weitere Ablaufverf ahren ftir das beschriebene Bussystem 
denkbar. Diese werden jedoch nicht beschrieben, da es sich urn 
freie Ausgestaltungsmoglichkeiten handelt, die vom hier 
auf zuzeigenden Grundprinzip unabhangig sind. 
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3 Kurzbeschreibung der Diagrsmme 

Figur 1 : Zeichnung eines Basisbausteines als FPGA Typ A 

Figur 2 : Zeichnung eines Basisbausteines als FPGA Typ B 

Figur 3 : Zeichnung eines Basisbausteines als DFP 

Figur 4 : LeitungsbUndelung in FPGAs 

Figur 5 : Leitungsbundelung in DFPs 

Figur 6 : Eine OUTPUT-CELL 

Figur 7 : Eine INPUT-CELL 

Figur 8 : Die Adressgenerierung 

Figur 9 : Komplettes Bussystem mit Steuerung 

Figur 10 : AnschluB von Speicher und Peripherie 

Figur 11 : Das EB-REG 

Figur 12 : Ausf ahrungsbeispiel 

Figur 13 : Ausfuhrungsbeispiel 2 

Figur 14 : Bus-IO des zweiten Ausfuhrungsbeispiels 
Figur 15a: Adress-Generator des weiten Ausfuhrungsbeispiels 
Figur 15b: Alternativer Adress-Generator der eine End-of-Data 
Kennung erzeugt 

Figur 15c: Funktionsablauf beim Adress-Generator mit End-of-Data 
Kennung 

Figur 16 : Zusammenspiel zweier Segmente bei der indirekten 
Adressierung. 

Figur 17 : Die State-Machine far die indirekte Adressierung 
4 Detailbeschreibung der Diagramme 

Figur 1 zeigt einen FPGA nach dem Stand der Technik. 0101 stellt 
die internen Bussysteme dar, 0102 beinhaltet eine oder mehrer 
FPGA-Zelle(n) . 0103 sind Teilbusse, die eine Teilmenge von 0101 
darstellen und uber Schalter (Crossbars) mit 0101 verbunden sind. 
0103 kann auch interne Daten von 0102 verwalten, die nicht auf 
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0101 geschaltet werden. Die FPGA-Zellen sind in einem 2- 
dimensionalen Array angeordnet. 

0104 stellt eine Kantenzelle dar, die am Rand des Arrays sitzt 
und sich somit in nSchster Nahe zu den Anschlussen am Rand des 
Bausteins befindet. 

Figur 2 zeigt einen weiteren FPGA nach dem Stand der Technik. 
Diese Ausf uhrungsmoglichkeit arbeitet nicht mit Bussystemen wie 
0101 sondern hauptsachlich mit Next-Neighbour-Verbindungen 

(0201) , das sind direkte Verbindungen von einer FPGA-Zelle (0203) 
zu ihrer Nachbarzelle. Es konnen dennoch globale Bussysteme 

(0202) existieren, diese sind jedoch nicht sehr breit.Die FPGA- 
Zellen oder eine Gruppe von FPGA-Zellen besitzen eine Verbindung 
zu 0202, Die FPGA-Zellen sind in einem 2-dimensionalen Array 
angeordnet. 0204 stellt eine Kantenzelle dar, die am Rand des 
Arrays sitzt und sich somit in nachster Nahe zu den Anschlussen 
am Rand des Bausteins befindet. 

Figur 3 zeigt einen DFP nach DE 196 51 075.9. Dabei sind die PAE- 
Zellen (0303) uber ein Businterface (0304) auf die Bussysteme 
(0301) geschaltet. Die Bussysteme 0301 k5nnen iiber einen 
Busschalter (0302) miteinander verschaltet werden. Die PAE-Zellen 
sind in einem 2-dimensionalen Array angeordnet. 0305 stellt eine 
Kantenzelle dar, die am Rand des Arrays sitzt und sich somit in 
nachster NShe zu den AnschlOssen am Rand des Bausteins befindet. 

Figur 4a zeigt eine FPGA-Kante nach Figur 1. Au&erhalb der 
Kantenzellen (0401) ist eine Mehrzahl von INPUT-/OUTPUT-CELLs 
(0402) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0403) mit dem E-BUS (0404) verbinden. Dabei ist die 
Menge der INPUT- / OUTPUT-CELLs von ihrer eigenen Breite im 
Verhaltnis zur Breite der internen Bussysteme abhangig. 0405 
stellt ein EB-REG dar. 0406 stellt eine Zustandsmaschine dar. Von 
der Zustandsmaschine geht zum EB-REG und jeder einzelnen INPUT- 
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/OUTPUT-CELL ein Bussystem (0407), Uber das die Zustandsmaschine 
die INPUT- /OUTPUT-CELLs steuert. Dabei k6nnen mehrere 0405 und 
0406 existieren, indem je eine Menge an 04 02 zu Gruppen 
zusammengef aiit werden und von je einer 0405 und 0406 verwaltet 
werden . 

Figur 4b zeigt eine FPGA-Kante nach Figur 2. AuBerhalb der 
Kantenzellen (0411) ist eine Mehrzahl von INPUT- /OUTPUT-CELLs 
(0412) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0413) und die direkten Verbindungen der Kantenzellen 
(0417) mit dem E-BUS (0414) verbinden. Dabei ist die Menge der 
INPUT- /OUTPUT-CELLs von ihrer eigenen Breite im Verhaitnis zur 
Breite der internen Bussysteme (0413) und der Menge der direkten 
Verbindungen (0418) abhangig. 0415 stellt ein EB-REG dar. 0416 
stellt eine Zustandsmaschine dar. Von der Zustandsmaschine gent 
zum EB-REG und jeder einzelnen INPUT- /OUTPUT-CELL ein Bussystem 
(0417), ttber das die Zustandsmaschine die INPUT-/OUTPUT-CELLs 
steuert. 

Dabei k6nnen mehrere 0415 und 0416 existieren, indem je eine 
Menge an 0412 zu Gruppen zusammengefaBt werden und von je einer 
0415 und 0416 verwaltet werden. 

Figur 5 zeigt eine DFP-Kante nach Figur 3. Aufierhalb der 
Kantenzellen (0501) ist eine Mehrzahl von INPUT-/OUTPUT-CELLs 
(0502) angeordnet, die zu mehreren oder einzeln die internen 
Bussysteme (0503) mit dem E-BUS (0504) verbinden. Dabei ist die 
Menge der INPUT-/OUTPUT-CELLs von ihrer eigenen Breite im 
Verhaltnis zur Breite der internen Bussysteme (0503) abhangig. 
0505 stellt ein EB-REG dar. 0506 stellt eine Zustandsmaschine 
dar. Von der Zustandsmaschine geht zum EB-REG und jeder einzelnen 
IN PUT- /OUTPUT-CELL ein Bussystem (0507), uber das die 
Zustandsmaschine die INPUT-/OUTPUT-CELLs steuert. Dabei konnen 
mehrere 0505 und 0506 existieren, indem je eine Menge an 0412 zu 
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Gruppen zusammengef afct werden und von je einer 0505 und 0506 
verwaltet werden. 

Figur 6 zeigt eine OUTPUT-CELL 0601. Auflerhalb 0601 befindet sich 
das EB-REG (0602) und die Zustandsmaschine (0603) , sowie.ein Tor 

(0604) f das die Zustandsmaschine auf den E-BUS (0605) schaltet, 
sofern sie E-BUS-MASTER ist. Auf das EB-REG kann liber den E-BUS 

(0605) , den I-BUS (0613) und den Ladelogikbus (0609) zugegriffen 
werden. 

Weiterhin kann bei einem Rucksetzten des Bausteins (Reset) uber 
einen externen Anschluft (0614) , der aus dem Baustein 
herausgef uhrt ist, das MASTER-Bit gesetzt werden. Die 
Zustandsmaschine (0603) greift schreibend und lesend auf 0602 zu. 
In der OUTPUT-CELL befindet sich ein Multiplexer (0606), der die 
Steuerung des E-GATE (0607) entweder dem E-BUS-MASTER oder der 
Zustandsmaschine (0603) zuordnet. 

Das MODE-PLUREG (0608) wird tiber den Ladelogikbus (0609) oder den 
I-BUS (0613) eingestellt und .konf iguriert den Adresszahler 
(0610), sowie die Zustandsmaschine (z.B. ausmaskieren der OUTPUT- 
CELL). Werden Daten des I-BUS (0613) in das I -GATE-REG (0611) 
gespeichert, wird der Zugriff im SET-REG (0612) vermerkt. Der 
Zustand von 0612 ist Uber 0607 am E-BUS abfragbar. Ein lesender 
Zugriff (das E-GATE 0607 ist aktiviert) setzt 0612 zurtick. Die 
von 0610 generierten Adressen und die Daten von 0611 werden Uber 
das Tor 0607 auf den E-BUS ubertragen. Es besteht die Moglichkeit 
die OUTPUT-CELL statt uber die Ladelogik Uber den Baustein (DFP, 
FPGA f DPGA, o.a\) 

selbst dynamisch umzukonf igurieren und zu steuern. Hierzu dient 
der der I-BUS-AnschluB an das EB-REG (0602) und das MODE-PLUREG 
(0608) . 

Figur 7 zeigt eine INPUT-CELL 0701. Aufterhalb 0701 befindet sich 
das EB-REG (0702) und die Zustandsmaschine (0703), sowie ein Tor 
(MASTER- GATE) (0704), das die Zustandsmaschine auf den E-BUS 
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(0705) schaltet, sofern sie E-BUS-MASTER ist. Auf das EB-REG kann 
ttber den E-BUS (0705), den I-BUS (0713) und den Ladelogikbus 

(0709) zugegriffen werden. Weiterhin kann bei einem RUcksetzten 
des Bausteins (Reset) ttber einen externen Anschluft (0714) , der 
aus dem Baustein herausgefUhrt ist, das MASTER-Bit gesetzt 
werden. Die Zustandsmaschine (0703) greift schreibend und lesend 
auf 0702 zu. In der INPUT-CELL befindet sich ein Multiplexer 

(0706) , der die Steuerung des E-GATE-REG (0707) entweder dem E- 
BUS-MASTER oder der Zustandsmaschine (0703) zuordnet. Das MODE- 
PLUREG (0708) wird liber den Ladelogikbus (0709) oder den I-BUS 
(0713) eingestellt und konfiguriert den Adresszahler (0710) , 
sowie die Zustandsmaschine (z.B. ausmaskieren der INPUT-CELL). 
Werden Daten des E-BUS (0705) in das E-GATE-REG (0707) 
gespeichert, wird der Zugriff im SET-REG (0712) vermerkt. 

Der Zustand von 0712 ist Uber ein Tor (0715), dessen Steuerung 
die selbe wie beim Latch (0707) ist, am E-BUS abfragbar. Ein 
lesender Zugriff, das E-GATE 0711 ist aktiviert und die Daten 
gelangen auf den I-BUS (0713). setzt 0712 Uber 0717 zuruck. 
Alternativ kann 0712 uber die Zustandsmaschine (0703) 
zurtlckgesetzt werden (0718) . 

Die von 0710 generierten Adressen werden ttber das Tor (ADR-GATE) 
0716 auf den E-BUS tibertragen, 0716 wird von der Zustandsmaschine 
(0703) aktiviert, wenn diese E-BUS-MASTER ist. Es besteht die 
Mijglichkeit die INPUT-CELL statt uber die Ladelogik uber den 
Baustein (DFP, FPGA, DPGA, o.S.) selbst dynamisch 
umzukonfigurieren und zu steuern. Hierzu dient der der I-BUS- 
Anschlufi an das EB-REG (0702) und das MODE-PLUREG (0708). 

Figur 8 zeigt das MODE-PLUREG (0801) einer INPUT- oder OUTPUT- 
CELL, das Uber den Ladelogikbus (0802) von der Ladelogik oder 
tiber einen I-BUS (0808) beschrieben wird. 
Das jeweilige Bussystem wird uber den Multiplexer (0809) 
ausgewahlt, dabei ist die Steuerung des Multiplexers nicht 
eingezeichnet, da eine gewohnliche Dekodierlogik verwendet werden 
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kann. Die ZShlereinstellungen, wie" Schrittbreite, Zahlrichtung 
und Freischaltung des Zahlers werden direkt (0807) an den Zahler 

(0803) geleitet. Die Grundadresse Jcann entweder uber einen Load 

(0804) direkt in den ZShler geschrieben (0805) werden, oder in 
einem Zusatz (0811) zu 0801 zwischengespeichert werden. Die far 
die Zustandsmaschine relevanten EintrSge in 0801 gelangen Uber 
ein Tor (0806), das von der Zustandsmaschine fur die jeweilig 
aktivierte INPUT- oder OUTPUT-CELL geSffnet wird, zur 
Zustandsmaschine . 

Figur 9a zeigt eine Businterfaceschaltung mit Zustandsmaschine 
(0901), MASTER-GATE (0902) und EB-REG (0903). Die INPUT-CELLs 
(0904) transferieren Daten vom E-BUS (0905) auf den II-BUS 
(0906). Die OUTPUT-CELLs (0907) transferieren Daten vom IO-BUS 
(0908) auf den E-BUS (0905). Ober den Steuerbus (0909) sind 
samtliche Baugruppen miteinander verbunden. 

Figur 9b zeigt eine Businterfaceschaltung mit Zustandsmaschine 
(0901), MAS \-TER-GATE (0902) und EB-REG (0903). Die INPUT-CELLs 
(0904) transferieren Daten vom E-BUS (0905) auf den 
bidirektionalen I-BUS (0910). Die OUTPUT-CELLs (0907) 
transferieren Daten vom bidirektionalen I-BUS (0910) auf den E- 
BUS (0905). Ober den Steuerbus (0909) sind sfimtliche Baugruppen 
miteinander verbunden. Es sind auch Interfaceschaltungen denkbar, 
die beide MOglichkeiten (Fig. 9a und 9b) gemischt 
verwenden. 

Figur 10a zeigt zwei Bausteine (DFPs, FPGAs / DPGAs, o.a.) (1001) 
Ober den E-BUS (1002) miteinander vernetzt. 

Figur 10b zeigt die Vernetzung einer Mehrzahl von Bausteinen 
(DFPs, FPGAs , DPGAs, o.a.) (1001) uber den E-BUS (1002). 
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Figur 10c zeigt die Vernetzung einer Mehrzahl von Bausteinen 
(DFPs, FPGAs, DPGAs, o.a.) (1001) uber den E-BUS (1002). Die 
Vernetzung kann zu einer Matrix ausgebaut werden. Ein Baustein 
(1001) kann auch eine Mehrzahl von Bussystemen (1002) verwalten. 

Figur lOd zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a\) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) uber den E-BUS (1002). 

Figur lOe zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) iiber den E-BUS (1002). 

Figur lOf zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a.) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) und mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) Uber den E-BUS (1002). 

» 

Figur lOg zeigt die Vernetzung eine Bausteins (DFPs, FPGAs, 
DPGAs, o.a\) (1001) mit einem Speicherbaustein oder einer 
Speicherbank (1003) und mit einem Peripheriebaustein oder einer 
Peripheriegruppe (1004) und einem weiteren Baustein (DFPs, FPGAs, 
DPGAs, o.a\) (1001) Uber den E-BUS (1002). 

Figur 11 zeigt den Aufbau des EB-REG, Die Bussysteme E-BUS 
(1103); Ladelogikbus (1104), Uber welchen die Ladelogik Zugriff 
auf das EB-REG hat und der lokale interne Bus zwischen den INPUT- 
/OUTPUT-CELLs, der Zustandsmaschine und dem EB-REG (1105, vgl. 
0407, 0417, 0517), sowie mfcglicherweise ein I -BUS (1114) werden 
auf einen Multiplexer (1106) gefuhrt. Der Multiplexer (1106) 
wahlt entweder einen der Busse oder die Ruckkopplung auf das 
Register (1108) aus und schaltet die Daten zum Eingang des 
Registers (1108) durch. Das MASTER-Bit wird getrennt Uber den 
Multiplexer (1107) zum Register (1108) gefUhrt. Der Multiplexer 
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wird uber das RESET-Signal (1101) (RUcksetzen Oder Initialisieren 
des Bausteines) gesteuert. Liegt ein RESET an, so schaltet der 
Multiplexer (1107) das Signal eines externen Chipanschlusses 
(1102) auf den Eingang des Registers (1108) durch, andernfalls 
wird der Ausgang des Multiplexers (1106) auf den Eingang des 
Registers (1108) durchgeschaltet . Dadurch kann MASTER vorbelegt 
werden. Das Register (1108) wird uber den Systemtakt (1112) 
getaktet. Der Inhalt des Registers (1108) wird Uber ein Tor 
(1109, 1110, 1111, 1113) auf das jeweils lesend zugreifenden 
Bussystem (1103, 1104, 1105, 1114) geschaltet. 
Die Steuerung der Tore (1109, 1110, 1111, 1113), sowie des 
Multiplexers (1106) ist nicht eingezeichnet, da eine gewohnliche 
Dekodierlogik verwendet werden kann. 

5 Ausfuhrungsbeispiele 

Figur 12 zeigt ein Beispiel i?ei dem das Standardbussystems RAMBUS 
(1203) eingesetzt wird. Ein Baustein (DFPs, FPGAs, DPGAs, o.a.) 
(1201) ist uber das Bussystem (1203) mit weiteren Baugruppen 
(Speicher, Peripherie, weitere DFPs, FPGAs, DPGAs, o.a.) (1202) 

verbunden. Der Baustein (1201) kann unabhangig vom Bussystem 
(1203) weitere AnschluBleitungen (1204), z.B wie nach dem Stand 

der Technik tiblich, zum Anschlufi beliebiger Schaltkreise 

aufweisen. 

Figur 13 zeigt ein Implementierungsbeispiel fur ein 10- und 
Speicherbussystem. 1310 bildet den Rambus, der die Rambus- 
Interface (1308) mit dem Rambus-Speicher verbindet. Das Rambus- 
Interface ist mit einem Cache-Ram (1306) verbunden. Dem Cache-Ram 
(1306) ist ein Tag-Ram (1307), sowie ein Cache-Controller (1305) 
zugeordnet. Mit Hilfe des Cache-Controllers und des Tag-Ram wird 
geprttft ob angeforderte Daten im Cache-Speicher vorhanden sind 
Oder ob sie aus dem externen Rambus-Speicher geladen werden 
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mOssen. Gesteuert werden der Cache-Ram, der Cache-Controller und 
das Rambus-Interface von einer State-Machine (1304). Der Cache 
wird nach dem Stand der Technik implement iert . 

Der Arbiter (1303) regelt den Zugriff der einzelnen Bussegmente 
auf die Cache-Ram und somit auch auf den externen Speicher. Bei 
diesem Implementierungsbeispiel kann auf acht Bussegmente 
zugegriffen werden. Jede Verbindung zu einem Bussegment (1309) 
besitzt eine Bus-IO (1301) und einen Address-Generator (1302). 
Aufierdem ist jede Bus-IO noch mit dem Ladelogikbus (1307) 
verbunden, sowie mit einem internen Test-Bus (1311). Jede n-te 
Bus-IO ist mit der (n+l)-ten Bus-IO verbunden, wobei fur n gilt n 
3, 5,...) . Durch diese Vebindung konnen Daten, die von dem n-ten 
Adress-Generator aus dem Speicher angefordert wurden, vom (n+1)- 
ten Segment als Adresse fur einen Speicherzugrif f benutzt werden. 
Damit ist eine indirekte Adressierung des Speichers moglich. Der 
Wert des Zahlers (1509) des Segmentes n zeigt auf eine 
Speicherstelle im Ram. Die Daten aus dieser Speicherstelle werden 
zum Segment (n+1) tibertragen und dienen dort als Base-Adresse zur 
Adressierung des Speichers. 

Figur 14 zeigt die Bus-IO Einheit. Sie ist mit dem internen 
Bussystem (1406), dem Test-Bussystem (1408) sowie dem 
Ladelogikbus (1407) verbunden. Der Bus (1412) und der Bus (1413) 
dient zur Verbindung der n-ten Bus-IO mit der (n+1) -ten Bus IO. 
Das heiBt der Bus (1413) ist nur bei jedem n-ten Segment und der 
Bus (1412) ist nur bei jedem (n+1) -ten Segment vorhanden. Dabei 
sendet die n-te Bus-IO Daten iiber den Bus (1413) und die (n+l)-te 
Bus-IO empfangt diese Daten durch den Bus (1412). Die Bussysteme 
(1406, 1407, 1412) werden Ober die Tore (1401, 1402, 1403, 1411) 
auf den Bus (1409) geschaltet, der die Bus-IO mit dem Adress- 
Generator verbindet. Der Arbiter (1404) wahlt ein Bussystem 
(1406, 1407, 1412) zur Datenubertragung aus und gibt ein 
Steuersignal an die State-Machine (1405), die ihrerseits die Tore 
(1401, 1402, 1403, 1411) steuert. Aufcerdem sendet die State- 

m 
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Machine (1405) noch Steuersignale (1410) an den Adress-Generator 
und das Ram. 

Es gibt zwei Moglichkeiten: 

a) Segment n: Die State-Machine (1405) erhait vom Adress- 
Generator ein Konf igurationssignal (1415), das festgelegt ob eine 
indirekte Adressierung erfolgen soil. Nach einem Read- Trigger- 
Signal (1416) vom internen Bus (1406) Oder dem Ladelogikbus 
(1407) schaltet die State Machine (1405) das zugehdrige Tor 
(1401, 1402, 1403, 1411) frei und erzeugt die Steuersignale 
(1410). Die durch den ladbaren Auf /Ab-Zahler (1509) adressierte 
Speicherstelle wird ausgelesen. Die in der Ram Speicherstelle 
enthaltenen Daten, werden nicht zum Bus zuriickgeschickt, sondern 
durch den Bus (1413) zum (n+l)-ten Segment ubertragen und dienen 
dort als Base-Adresse zur Adressierung des Ram. Die State-Machine 
(1405) gibt ein Acknowledge Signal zur Synchronisation nach 
erhalt der Daten vom Ram an die State Machine (1414), die den 
Ablauf bei der indirekten Adressierung steuert. Diese State 
Machine (1414) wird im folgenden Ind-State-Machine genannt. Sie 
erzeugt alle bendtigten Kontrollsignale und schickt diese zum 
nachfolgenden Segment (1413). 

b) Segment (n+1): Durch den Bus (1412) empfangt das (n+l)-te 
Segment, die vom n-ten Segment ubertragenen Daten. Der Arbiter 
(1404) bekommt ein Write Signal und schickt seinerseits eine 
Anforderung an die State-Machine, die das Tor (1411) 
freischaltet. Das Tor (1411) fttgt den Daten von 1412 die interne 
Adresse des Base-Adressen Eintrags zu, damit der Decoder (1502) 
die Base-Adressen-Latches freischaltet. 

Figur 15a zeigt den Adress-Generator. Ober den Bus (1409) werden 
Daten und Adressinformationen von der Bus-IO in den Adress- 
Generator ubertragen. Der Bus (1410) ttbertragt die 
Kontrollsignale CLK (1517, 1508) und das Output-Enable-Signal 
(1518), sowie die Steuersignale zum Ram (1519). Das Output- 
Enable-Signal (1518) schaltet die Tore (1503, 1515) frei. Tor 
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(1503) schaltet die Daten von Bus (1409) auf den Datenbus (1504) 
zum Ram. Das Tor (1515) schaltet die erzeugten Adressen auf den 
zum Ram fuhrenden Adress-Bus (1520) - 
Die Adressen werden auf folgende Art generiert: Im 
Adressgenerator gibt es vier Eintrage, die zur Adressgenerierung 
dienen. Jeder Eintrag wird in zwei Latches (1501) gespeichert, 
wobei ein Latch die h5herwertige Adresse und das andere Latch die 
niederwertige Adresse speichert. Der Base-Adressen Eintrag 
enthSlt die Startadresse eines Speicherzugrif fs. Der Step-Width 
Eintrag wird im ladbaren Auf /Ab-Zahler (1509) zur Base-Adresse 
hinzuaddiert oder abgezogen. Die Funktion (Auf/Ab) des ladbaren 
Auf /Ab-zahlers (1509) wird in einem Bit der Base-Adresse kodiert 
und zum ladbaren Auf /Ab-Zahler (1509) ubertragen. 
Im End-Adressen Eintrag wird die Endadresse gespeichert und in 
einem Bit kodiert, ob die Adressgenerierung beim Erreichen der 
Endadresse abbricht oder der End-Adressen Eintrag ignoriert wird. 
Soli bis zu einer Endadresse gezahlt werden, wird der Wert des 
End-Adress-Eint rages mit dem .Ausgangswert des ladbaren Auf /Ab- 
Zahlers verglichen. Dies geschieht im Komparator (1510), der 
sobald die Endadresse erreicht oder iiberschritten ist, einen 
Highpegel erzeugt. Bei aktivem Enable-End-Address Signal (1507) 
gibt das UND-Gatter (1512) diesen Highpegel zum ODER-Gatter 
(1514), das dann ein Trigger-Signal (1521) zum Ladelogikbus 
weitergibt . 

Im Data-Count Eintrag steht die Anzahl der Datentransfers und 
somit der zu berechnenden Adressen. Auch hier wird iiber ein Bit 
im Data-Count Eintrag festgelegt, ob diese Funktion aktiviert ist 
und das Enable-Data-Counter Signal (1506) zum UND-Gatter (1513) 
geleitet wird oder der Data-Count Eintrag ignoriert wird. Der 
Zahler (1505) ubernimmt den Wert des Data-Count Eintrags und 
dekrementiert ihn bei jedem Clockimpuls urn Eins. Der Vergleicher 
(1511) vergleicht den Wert des Zahlers (1505) auf Null und gibt 
ein Signal zum UND-Gatter (1513). Ist das Enable-Data-Counter 
Signal (1506) aktiv, wird das Signal des Komparators (1511) zum 

25 



WO 98/28697 



PCT/DE97/03D13 



ODER-Gatter (1514) geleitet und als Tigger-Signal (1521) zum 
Ladelogikbus geleitet. 

Bestandteil des Busses (1409) sind Steuersignale und Adressen fur 
den Decoder (1502),. der eines der Latche (1501) entsprechend der 
Adresse auswShlt. Ober den Decoder (1502) laftt sich auch das 
Konf igurationsregister (1516) ansteuern, das festlegt ob das 
Segment ftir indirekte Adressierung verwendet wird. Die Daten des 
Konfigurationsregisters werden Qber die Verbindung (1415) zur Bus 
10 des Segments iibertragen. 

Figur 15b zeigt eine Abwandlung des Adress-Generators aus 
FigurlSa, der am Anfang eines Datenblocks im Speicher, die 
Endadresse des Datenblocks ablegt. Der Vorteil dieser AusfOhrung 
besteht darin, dafi variabler Grofte des Datenblocks, das Ende fur 
spatere Zugriffe exakt definiert ist. Der Aufbau entspricht 
grundsatzlich dem Aufbau des Adress-Generators aus Figur 15a, 
jedoch mit der Erweiterung urn zwei Multiplexer (1522, 1523) und 
einem zusatzlichen Eintrag inu Konf igurationsregister (1523) . 
Dieser Eintrag wird im folgenden Calculate-End-Adress genannt 
und legt fest, ob die Endadresse des Datenblocks als erster 
Eintrag des Datenblocks an der durch den Base_Adressen Eintrag 
definierten Stelle abgelegt wird. Die Multiplexer werden von der 
State-Machine (1405) angesteuert. Der Multiplexer (1522) dient 
dazu die Base-Adresse oder den Ausgang des Zalilers (1509) auf das 
Tor (1515) zu schalten. Der Multiplexer (1523) schaitet entweder 
die vom Bus (1404) kommenden Daten oder den Ausgang des Zahlers 
(1509) auf das Tor (1503). 

Figur 15c zeigt den Ablauf in der State-Machine und das Pattern 
des Speicherzugriffs durch den in Figur 15b dargestellten Adress- 
Generator. Die State-Machine (1405) befindet sich zunachst im 
IDLE Zustand (1524). Ist der Eintrag Calculate-End-Adress im 
Konfigurationregister (1523) jgesetzt, geht die State-Machine 
(1405) hach dem Schreiben der Step-Width (1529) in den Zustand 
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(1525) uber. Dort wird die Adresse fur den Zugriff auf das Ram 
aus dem Base-Adressen Eintrag in den ladbaren Auf /Ab-zahler 
geschrieben und die Step-Width - je nach ZShler-Mode (Auf/Ab) - 
addiert oder subtrahiert. Der Ram-Zugriff wird durchgefuhrt und 
die State-Machine gent wieder in den IDLE (1524) Zustand uber. 
Die folgenden Datentransf ers erfolgen wie durch die Base-Adressen 
und Step-Width Eintrage festgelegt. Damit sieht das Pattern im 
Speicher folgenderma lien aus. Die Base-Adresse (1526) wurde nicht 
beschrieben. Der erste Eintrag (1527) steht an der Position, die 
durch Base-Adresse plus (minus) Step-Width festgelegt wird. Die 
nachsten Eintrage (1528) folgen im Step-Width Abstand 
aufeinander. 

1st das Transferende erreicht, wird ein Trigger-Signal generiert 
(1521). Aufgrund des Trigger-Signals (1521) oder eines externen 
Trigger-Signals (1417) geht die State-Machine (1405) vom IDLE- 
Zustand (1524) in den Zustand (1530) uber. Dort werden die 
Multiplexer (1522, 1523) umg.eschaltet, so daft die Base-Adresse am 
Eingang von Tor (1515) anliegt und die Adresse nach dem Ende des 
Datenblocks an Tor (1503) anliegt- Danach geht die State-Machine 
(1405) in den Zustand (1531) und schreibt die Adresse nach dem 
Ende des Datenblocks an der Position der Base-Adresse ins Ram. 
Das Pattern im Speicher sieht dann f olgendermafien aus. Der 
Eintrag der Base-Adresse (1526) gibt die Adresse nach dem Ende 
des Datenblocks an. Der ersten Eintrag im Datenblock liegt an 
Adresse (1527), danach folgen die restlichen Eintrage. 
Eine weitere Ausgestaltungsmbglichkeit der State-Machine ist, daft 
aufgrund eines der Trigger-Signale (1521 oder 1417) die State- 
Machine zunachst den ZShlerstand in 1509 so korrigiert, daft 1509 
auf das letzte Datenwort des Datenblocks zeigt. Dies wird 
technisch realisiert, indem die inverse Operation zu der 
voreingestellten in 1509 durchgefuhrt wird, d.h. addiert 1509 
gemaft Voreinstellung die Step-Width, wird Step-Width nun 
subtrahiert; subtrahiert 1509 gemaft Voreinstellung, wird addiert. 
Urn die Korrektur durchzuf Uhren ist in der nachfolgend in Figur 
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15c beschriebenen State-Machine ein zusatzlicher Zustand (1540) 
notwendig, um 1509 entsprechend anzusteuern. 

Figur 16 zeigt das Zusammenspiel mehrerer Segmente bei der 
indirekten Adressierung . Das Segment n (1601) empfangt uber den 
Bus (1605) (der Ladelogikbus (1407) oder der interne Bus (1406)) 
ein Read Signal. Die Bus-IO (1603) schaltet das zugehorige Tor 
frei und erzeugt die bentftigten Kontrollsignale. Die durch 1509 
festgelegte Speicherstelle wird adressiert. Die vom Ram kommenden 
Daten (1607) werden zu Segment (n+1) (1602) geschickt. Die Ind- 
State-Machine (1604) erzeugt die bendtigten Kontrollsignale und 
schickt sie ebenfalls zu Segment (n+1) (1602). In Segment (n+1) 
(1602) passieren die Signale das in Figur 14 beschriebene Gate 
(1411) der Bus-IO (1608). Dort wird eine Adresse fur den in Figur 
15 beschriebenen Decoder (1502) hinzugefugt, so daft der Base- 
Adressen Eintrag des Adress-Generators (1608) von Segment (n+1) 
(1602) angesprochen wird. Die von Segment n (1601) kommenden 
Daten, dienen damit als Base-Adresse in Segment (n+1) (1602), das 
heifit ein Read/Write Zugriff Uber den Bus (1609) (der 
Ladelogikbus (1407) oder der interne Bus (1406)) kann diese Base- 
Adresse ftir einen Zugriff auf das Ram verwenden. Der Bus (1610) 
dient zur Ubertragung der Adressen zum Ram und der Bus (1612) 
tlbertragt die Daten von und zum Ram, abhangig ob ein Read oder 
Write Zugriff erfolgt. 

Figur 17 zeigt die Ind-State-Machine. Der Grundzustand ist der 
IDLE Zustand (1701). In diesem Zustand verbleibt sie bis zum 
Eintreffen des Acknowledge Signals der State-Machine (1405) aus 
Figur 14. Danach geht die Ind-State-Machine in den Zustand Write 
(1702) uber und erzeugt ein Write Enable Signal, das mit den 
Daten zu Segment (n+1) geschickt wird. Es dient dort dazu, den 
Decoder, der die verschiedenen Eintrage auswahlt, zu aktivieren. 
AnschlieBend erfolgt der Obergang zum Zustand Wait_for_Ack. Nach 
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dem Acknowledge Signal des Segments (n+1) geht die Ind-State- 
Machine wieder in den IDLE (1-701) Zustand. 
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6 Begrif f sdefinition 

ADR- GATE Tor, das die Adressen auf den E-BUS aufschaltet, sofern 
der Baustein E-BUS-MASTER ist.} 

DFP DatenfluBprozessor nach Patent/Of fenlegung DE 44 16 881 

DPGA Dynamisch konf igurierbare FPGAs. Stand der Technik 

D-FlipFlop Speicherelement, welches ein Signal bei der 
steigenden Flanke eines Taktes speichert. 

EB-REG Register, das sie Statussignale zwischen I-BUS und E- 
BUS speichert. 

E-BUS Externes Bussystem aufterhalb eines Baust eines. 

E-BUS-MASTER Baustein, der den E-BUS steuert. Aktiv. 

E-BUS-SLAVE Baustein, der vom E-BUS-MASTER angesprochen wird. 
Passiv. 

E-GATE Tor, das von der bausteininternen Zustandsmaschine oder 
vom E-BUS-MASTER gesteuert wird und Daten auf den E-BUS 
aufschaltet. 

E-GATE-REG Register in das die Daten eingestragen werden, die 
tiber das E-GATE auf den E-BUS Obertragen werden. 

E-READ Flag im EB-REG, das anzeigt, daft die OUTPUT-CELLs 
komplett auf den E-BUS Ubertragen wurden. 

E -WRITE Flag im EB-REG, das anzeigt, daft der E-BUS komplett in 
die INPUT-CELLs Ubertragen wurde. 
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Flag (Fahne). Statusbit in einem Register, das einen Zustand 

anzeigt. 

FPGA Programmierbarer Logikbaustein. Stand der Technik. 

Handshake Signalprotokoll, bei dem ein Signal A einen Zustand 
anzeigt und ein anderes Signal B bestatigt, daft es 
Signal A akzeptiert und darauf reagiert (hat) . 

INPUT-CELL Baugruppe, die Daten vom E-BUS auf einen I-BUS 
iibertragt . 

I- BUSn (auch I-BUS) Bausteininternes Bussystem, das auch aus 

BUndeln von einzelnen Leitungen bestehen kann. n gibt 
die Nummer des Busses an. 

II- BUSn (auch II-BUS) Bausteininternes Bussystem, das auch aus 

Bundeln von einzelnen Leitungen bestehen kann. Der Bus 
wird von einer INPUT-CELL getrieben und geht auf 
logische Eingange. n gibt die Nummer des Busses an. 

IO-BUSn (auch IO-BUS) Bausteininternes Bussystem, das auch aus 
Bundeln von einzelnen Leitungen bestehen kann. Der Bus 
wird von logischen Ausgangen getrieben und geht an eine 
OUTPUT-CELL, n gibt die Nummer des Busses an. 

I -GATE Tor, das Daten auf den I-BUS aufschaltet. 

I-GATE-REG Register, das von der bausteininternen 

Zustandsmaschine oder vom E-BUS-MASTER gesteuert wird 
und in das die Daten eingestragen werden, die uber das 
I -GATE auf den I-BUS iibertragen werden. 
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I-READ Flag ira EB-REG, das anzeigt, dafi die INPUT-CELLs 
komplett auf den I-BUS ubertragen wurden. 

I -WRITE Flag im EB-REG, das anzeigt, dafl der I-BUS komplett in 
die OUTPUT-CELLs Ubertragen wurde. 



Kantenzelle Zelle am Rand eines Zellarrays, oftmals mit direktem 
Kontakt zu den Anschlussen eines Bausteines. 

Konfigurieren Einstellen der Funktion und Vernetzung einer 

logischen Einheit, einer (FPGA) -Zelle (Logikzelle) Oder 
einer PAE (vgl. umkonf igurieren) . 

Ladelogik Einheit zum Konfigurieren und Umkonf igurieren 

einer PAE oder Logikzelle. Ausgestaltet durch einen 
speziell an seine Aufgabe angepafiten Mikrokont roller. 



Latch Speicherelement, d^s ein Signal fur gewohnlich 

wahrend des H-Pegels transparent weiterleitet und 
wahrend des L-Pegels speichert. In PAEs werden 
teilweise Latches gebraucht, bei denen die Funktion der 
Pegel genau umgekehrt ist. Hierbei wird vor den Takt 
eines iiblichen Latch ein Inverter geschaltet. 



Logikzellen Bei DFPs, FPGAs , DPGAs verwendete konf igurierbare 
Zellen, die einfache logische oder arithmetische 
Aufgaben gemaft ihrer Konf iguration erfullen- 

MASTER Flag im EB-REG, das anzeigt, daJi der Baustein E-BUS- 
MASTER ist. 



MODE-PLUREG Register in dem die Ladelogik die Konf iguration einer 
INPUT- / OUTPUT-CELL einstellt. 
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OUTPUT-CELL Baugruppe, die Daten von einem I-BUS auf den E-BUS 
iibertragt. 

PAE Processing Array Element: EALU mit O-REG, R-REG, 

R20\-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, 
StateBack- und Power-UNIT. 

PLU Einheit zum Konf igurieren und Umkonf igurieren 

einer PAE oder Logikzelle. Ausgestaltet durch einen 
speziell an seine Aufgabe angepaftten Mikrokontroller . 

REQ-MASTER Flag im EB-REG, das anzeigt, daft der Baustein E- 
BUS-MASTER werden m6chte. 

RS-FlipFlop Reset-/Set-FlipFlop. Speichefelement, das durch 2 
Signale umgeschaltet werden kann. 

SET-REG Register das anzeigt, daft Daten in ein I -GATE-REG oder 
E-GATE-REG geschrieben und noch nicht gelesen wurden. 

STATE-GATE Tor, das den Ausgang des SET-REG auf den E-BUS 
schaltet. 

Tor Schalter, der ein Signal weiterleitet oder sperrt. 

Einfacher Vergleich: Relais 

Umkonf igurieren Neues Konf igurieren von einer beliebigen Menge 
von PAEs oder Logikzellen wMhrend eine beliebige 
Restmenge von PAEs oder Logikzellen ihre eigenen 
Funktionen fortsetzen (vgl, konf igurieren) . 

Zustandsmaschine Logik, die diversen Zustanden annehmen kann. 

Die Obergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese 

-v 

33 



WO 98/23697 PCT/DE97/03013 

Maschinen werden zur Steuerung komplexer Funktionen 
eingesetzt und entsprechen dem Stand der Technik} 
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Patentanspriiche 

1. Bussystem, hergestellt durch Bundelung mehrere einzelner 
Leitungen oder Busse oder Teilbusse (vgl. Fig. 4/5) innerhalb 
eines Bausteines der Gattung DFP, FPGA, DPGA, sowie alien 
Bausteinen mit zwei- oder mehrdimensionaler prograiranierbare 
Zellstruktur (vgl. Fig. 1/2/3), tiber welches die Bausteine zu 
Mehreren zusammengefaftt werden kdnnen und/oder Speicher und/oder 
Peripherie anschlieftbar ist (vgl. Fig. 10)* 

2. Bussystem nach Anspruch 1, dadurch gekennzeichnet, daft eine 
oder mehrere Schnittstellen (Fig. 6/7) die Zusammenfassung der 
Leitungen iibernehmen und das Bussystem erzeugen. 

3. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
eine oder mehrere Zustandsmaschine (n) (0703/0603) die 
Schnittstellen (vgl. Fig. 6/7) steuert/steuern . 

4. Bussystem nach Anspruch 1, 2 und 3, dadurch gekennzeichnet, 
daft 

die Zustandsmaschine auch den externen Bus steuert. 

5. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, 
daft daft ein Adressgenerator existiert (0610/0710), der die 
Adressen far die ttber den Bus zu kontaktierenden Bausteine 
generiert . 

6. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, 
daft 

die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengef aftt sein 
kann/kannen (vgl. Fig. 4/5), zum Schreiben und Lesen verwendet 
(vgl. Fig. 9a, I-BUS) . 
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7. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, da& 
die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengef aftt sein 
kann/kSnnen (vgl. Fig. 4/5) , entweder zum Schreiben oder Lesen 
verwendet (vgl. Fig. 9b, II-BUS, IO-BUS) . 

8. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen ein internes Bussystem oder mehrere interne 
Bussysteme, das/die aus mehreren Leitungen zusammengefafct sein 
kann/kbnnen (vgl. Fig. 4/5), nach Anspruch 6 und 7 gernischt 
betreiben. 

9. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
ein Register zur Verwaltung und Steuerung des Bussystems 
existiert (EB-REG, 0702, 0602) . 

10. Bussystem nach Anspruch 1, und 2, dadurch gekennzeichnet, daft 
die Bussteuerung durch einen Baustein (E-BUS-MASTER) erfolgt, de 
auf eine Vielzahl von untergeordneten Bausteinen (E-BUS-SLAVE) 
zugreift . 

11. Bussystem nach Anspruch 1, 2 und 10, dadurch gekennzeichnet, 
dafl 

die Bussteuerung dynamisch von einem Baustein (E-BUS-MASTER) an 
einen anderen ubergeben wird (MASTER-Eintrag im EB-REG) . 

12 . Bussystem nach Anspruch 1, 2, 10 und 11, dadurch 
gekennzeichnet, dafi 

ein untergeordneter Baustein (E-BUS-SLAVE) den Erhalt der 
Buskontrolle fordern kann (REQ-MASTER-Eintrag im EB-REG) . 

13. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
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ein Register existiert, das anzeigt, ob Daten in den 
Schnittstellen gespeichert sind (SET-REG, 0612/ 0712) . 

14. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen entweder direkt auf dera Baustein implementiert 
sind, Oder durch die Konf iguration von Logikzellen, das sind 
Zellen in DFP-, FPGA-, DPGA, oder ahnlichen Bausteinen, die 
einfache logische oder arithmetische Aufgaben gemSfi ihrer 

Konf iguration erf alien, entstehen. 

15. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
die Schnittstellen von einer Ladelogik und/oder dem Baustein 
selbst (vgl. Fig. 8/11) konfiguriert werden kdnnen. 

16. Bussystem nach Anspruch 1, 2 und 15, dadurch gekennzeichnet, 
daB 

die Ladelogik partiell auf dem Baustein integriert ist. 

17. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
Standardbussysteme eingesetzt werden konnen (vgl. Fig. 12). 

18. Bussystem nach Anspruch 1 und 2, dadurch gekennzeichnet, daft 
der Baustein weitere gew&hnliche Anschlusse nach bei DFPs, FPGAs, 
DPGAs, o.a. iiblicher Art besitzt (vgl. Fig. 12 1201, 1204). 
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